package com.huike.report.mapper;

import java.util.Date;
import java.util.Map;

import org.apache.ibatis.annotations.Param;

import com.huike.clues.domain.vo.IndexStatisticsVo;

/**
 * 首页统计分析的Mapper
 * @author Administrator
 *
 */
public interface ReportMapper {
	/**=========================================基本数据========================================*/
	/**
	 * 获取线索数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Integer getCluesNum(@Param("startTime") String beginCreateTime,
						@Param("endTime") String endCreateTime,
						@Param("username") String username);

	/**
	 * 获取商机数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Integer getBusinessNum(@Param("startTime") String beginCreateTime,
						   @Param("endTime") String endCreateTime,
						   @Param("username") String username);

	/**
	 * 获取合同数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Integer getContractNum(@Param("startTime") String beginCreateTime,
						   @Param("endTime") String endCreateTime,
						   @Param("username") String username);

	/**
	 * 获取合同金额
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Double getSalesAmount(@Param("startTime") String beginCreateTime,
						  @Param("endTime") String endCreateTime,
						  @Param("username") String username);


    /**=========================================今日简报========================================*/
	/**
	 * //今日线索数目
	 * @param date
	 * @return
	 */
	Integer  getTodayCluesNum(Date date,@Param("username") String username);

	/**
	 * //今日商机数目
	 * @param date
	 * @return
	 */
	Integer getTodayBusinessNum(Date date,@Param("username") String username);

	/**
	 * //今日合同数目
	 * @param date
	 * @return
	 */
	Integer getTodayContractNum(Date date,@Param("username") String username);

	/**
	 * //今日销售金额
	 * @param date
	 * @return
	 */
	Double getTodaySalesAmount(Date date,@Param("username") String username);



	/**=========================================待办========================================*/
	/**
	 * //待跟进线索数目
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	Integer getToallocatedCluesNum(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime);

	/**
	 * //待跟进商机数目
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	Integer getToallocatedBusinessNum(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime);

	/**
	 * 待分配线索数目
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	Integer getTofollowedCluesNum(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime);

	/**
	 * 待分配商机数目
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	Integer getTofollowedBusinessNum(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime);

	/** 漏斗查询======================================================================*/
    Integer getCluesNums(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime,@Param("username") String username);

	Integer getEffectiveCluesNums(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime,@Param("username") String username);

	Integer getBusinessNums(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime,@Param("username") String username);

	Integer getContractNums(@Param("beginCreateTime")String beginCreateTime,@Param("endCreateTime") String endCreateTime,@Param("username") String username);
}
